<?php
//------------------------------------------------------------ Contraintes d'accès de la page

	// on vérifie que cette page est appelée à partir de l'index et que l'utilisateur a le droit de suppression
	if(isset($_SESSION) && ($GLOBALS['USER']['level'] >= 5 || $GLOBALS['USER']['admin'])){
	
		// l'identifiant de la donnée à supprimer est indiqué par un entier
		if(isset($_GET['id']) && numericInt($_GET['id'])){

?>
<?php
//------------------------------------------------------------ Suppression des données

/********************************* Règles :

	- id doit désigner un seul type de disparition
	- Le type de disparition doit exister dans la BDD
	- Le type de disparition ne doit pas être lié à une autre entité

*****************************************/

	$statut = array(); // indique le statut du traitement du formulaire (echec ou succes) - tableau contenant les messages à afficher
	$erreur = false; // indique si une erreur a été rencontrée lors du traitement

	//---------------------------------- Contrôle des données ----------------------------------
		
	$nb_types_disparition = valueExists((int)$_GET['id'], "CODETYPEDISPARITION", "type_disparition", $connexion);
	
	if($nb_types_disparition == 0){ // le type de disparition n'existe pas
		$statut[] = "Le type de disparition indiqué n'existe pas";
		$erreur = true;
	}else{
		
		// On compte le nombre de liens entre le type de disparition et d'autres entités
		$query_recuperation_nb_liens_type_disparition = "SELECT COUNT(*) ";
		$query_recuperation_nb_liens_type_disparition .= "FROM type_disparition t, sortie s ";
		$query_recuperation_nb_liens_type_disparition .= "WHERE t.CODETYPEDISPARITION = s.CODETYPEDISPARITION ";
		$query_recuperation_nb_liens_type_disparition .= "AND t.CODETYPEDISPARITION = ".$_GET['id']." ";
		
		$result_recuperation_nb_liens_type_disparition = mysql_query($query_recuperation_nb_liens_type_disparition, $connexion) or logError("RECUPERATION NB LIENS TYPE DISPARITION-".$query_recuperation_nb_liens_type_disparition."-".mysql_error());
		
		if(mysql_num_rows($result_recuperation_nb_liens_type_disparition) == 1){ // on a réussi à récupérer les données du type de disparition à supprimer
			
			$tab_recuperation_nb_liens_type_disparition = mysql_fetch_row($result_recuperation_nb_liens_type_disparition);
			
			if($tab_recuperation_nb_liens_type_disparition[0] > 0){
				$statut[] = "Ce type est utilisé par ".$tab_recuperation_nb_liens_type_disparition[0]." sortie(s)";
				$erreur = true;
			}
			
		}else{
			$statut[] = "Une donnée n'a pas pu être vérifiée";
			$erreur = true;
		}
		
		mysql_free_result($result_recuperation_nb_liens_type_disparition);
		
	}
	
	//---------------------------------- Suppression du type de disparition ----------------------------------
	
	if(!$erreur){ // aucune erreur n'a été rencontrée jusqu'ici
	
		// Suppression des informations de la table TYPE_DISPARITION
		$query_suppression_type_disparition = "DELETE FROM type_disparition WHERE CODETYPEDISPARITION = ".$_GET['id'];
		$result_suppression_type_disparition = mysql_query($query_suppression_type_disparition, $connexion) or logError("SUPPRESSION TYPE DISPARITION-".$query_suppression_type_disparition."-".mysql_error());
		
		if($result_suppression_type_disparition === true){
			$statut[] = "Le type de disparition a été supprimé - redirection dans 2 sec...";
			logAction("TYPE DISPARITION (id: ".$_GET['id'].") SUPPRIME par ".capitalise($GLOBALS['USER']['prenom'])." ".mb_strtoupper($GLOBALS['USER']['nom'])." (".$GLOBALS['USER']['login'].")");
		}else{
			$statut[] = "Erreur critique lors de la suppression du type de disparition";
			$erreur = true;
		}

	}

?>
<?php
//------------------------------------------------------------ Affichage du statut
	
	if($erreur){
		boutonRetour("index.php?p=gestion/typedisparition_gere"); // appel à la fonction boutonRetour() définie dans fonctions.php
		afficherStatut($statut, 3); // appel à la fonction afficherStatut() définie dans fonctions.php
	}else{
		afficherStatut($statut, 1); // appel à la fonction afficherStatut() définie dans fonctions.php
		redirection("gestion/typedisparition_gere", 2);
	}

?>
<?php
	if($erreur){
?>
<div class="information">
	<div class="titre">Information</div>
	<h4>Erreurs de suppression :</h4>
	<p>
		Si la ressource à supprimer est liée à d'autres éléments, vous ne pourrez pas la supprimer.<br />
		Si vous souhaitez tout de même la supprimer, il vous faudra préalablement supprimer les éléments auxquels elle est liée.
	</p>
</div>
<?php
	}
?>
<?php
//------------------------------------------------------------ Accès refusé à la page

		}else{
			afficherStatut("Le type de disparition n'est pas ou mal indiqué", 3); // appel à la fonction afficherStatut() définie dans fonctions.php
		}

	}else{
		if(isset($_SESSION)){
			if(!isset($_SESSION['user_id'])){ // si l'utilisateur n'est pas connecté
				include("pages/connexion.php");
			}else{ // si l'utilisateur est connecté et qu'il n'a pas accès à la page, c'est qu'il n'a pas le droit d'utilisation nécessaire
				include("pages/401.htm");
			}
		}
	}

?>